<template>
  <div class="permission-container">
    <div class="app-container">
      <!-- 表格 -->
      <el-card>
        <div style="text-align: right; margin-bottom: 20px">
          <el-button type="primary" size="small" @click="hAdd('0',1)">添加权限</el-button>
        </div>
        <el-table
          border
          :data="list"
          row-key="id"
        >
          <el-table-column label="名称" prop="name" />
          <el-table-column label="标识" prop="code" />
          <el-table-column label="描述" prop="description" />
          <el-table-column label="操作">
            <template #default="{row}">
              <el-button v-if="row.type === 1" type="text" @click="hAdd(row.id,2)">添加</el-button>
              <el-button type="text" @click="hEdit(row)">编辑</el-button>
              <el-button type="text" @click="hDel(row.id)">删除</el-button>
            </template>
          </el-table-column>
        </el-table>
      </el-card>

      <!-- 新增权限的弹层 -->
      <el-dialog
        :visible.sync="showDialog"
        :title="isEdit ? '编辑权限':'新增权限'"
        @close="resetForm"
      >
        <!-- 表单内容 -->
        <el-form ref="myForm" label-width="100px">
          <el-form-item label="权限名称">
            <el-input v-model="formData.name" />
          </el-form-item>
          <el-form-item label="权限标识">
            <el-input v-model="formData.code" />
          </el-form-item>
          <el-form-item label="权限描述">
            <el-input v-model="formData.description" />
          </el-form-item>
          <el-form-item label="权限启用">
            <el-switch
              v-model="formData.enVisible"
              active-text="启用"
              active-value="1"
              inactive-text="不启用"
              inactive-value="0"
            />
          </el-form-item>
        </el-form>

        <template #footer>
          <div style="text-align: right;">
            <el-button @click="showDialog = false">取消</el-button>
            <el-button type="primary" @click="hSubmit">确定</el-button>
          </div>
        </template>
      </el-dialog>
    </div>
  </div>
</template>

<script>
import { addPermission, delPermission, getPermissionList, updatePermission } from '@/api/permisson'
import { transDataToTreeData } from '@/utils'
export default {
  data() {
    return {
      list: [],
      showDialog: false, // 是否显示弹层
      formData: {
        name: '', // 名称
        code: '', // 权限标识
        description: '', // 描述
        enVisible: '0', // 开启
        pid: '', // 添加到哪个节点下
        type: '' // 类型
      },
      isEdit: false
    }
  },
  created() {
    this.loadPermissionList()
  },
  methods: {
    // 获取数据 渲染页面
    async loadPermissionList() {
      try {
        const res = await getPermissionList()
        // console.log(res)
        this.list = transDataToTreeData(res.data)
      } catch (error) {
        console.log(error)
      }
    },
    // 区别页面级别和按钮级别的数据并保存
    hAdd(pid, type) {
      this.formData.pid = pid
      this.formData.type = type
      this.isEdit = false
      this.showDialog = true
    },
    hSubmit() {
      // 假装有兜底校验
      this.isEdit ? this.doEdit() : this.doAdd()
    },
    // 新增功能
    async doAdd() {
      try {
        await addPermission(this.formData)
        this.$message.success('添加成功')
        this.loadPermissionList()
        this.showDialog = false
      } catch (error) {
        console.log(error)
      }
    },
    // 清空表单重置校验
    resetForm() {
      this.$refs.myForm.resetFields()
      this.formData = {
        name: '',
        code: '',
        description: '',
        enVisible: '0',
        pid: '',
        type: ''
      }
    },
    // 删除权限
    hDel(id) {
      this.$confirm('您确定要删除该权限点吗?').then(async() => {
        const res = await delPermission(id)
        console.log(res)
        if (res.code !== 10000) return this.$message.error(res.message)
        this.$message.success(res.message)
        this.loadPermissionList()
      }).catch(error => error)
    },
    // 编辑回显
    hEdit(row) {
      this.isEdit = true
      this.formData = { ...row }
      this.showDialog = true
    },
    // 编辑功能
    async doEdit() {
      try {
        await updatePermission(this.formData)
        this.$message.success('添加成功')
        this.loadPermissionList()
        this.showDialog = false
      } catch (error) {
        console.log(error)
      }
    }
  }
}
</script>
